<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    div{
      width: 300px;
      height: 300px;
      border: 1px solid red;
      margin: 100px auto;
    }

    p {
      width: 100px;
      height: 100px;
      background-color: pink;
    }
  </style>
</head>
<body>
  <div>
    <p></p>
  </div>

  <script>
    var div = document.querySelector('div')
    var p = document.querySelector('p')

    //  先执行了 p的事件，再执行 div， 在冒泡阶段去执行的  stopPropagation 
    // div.onclick = function(e) {
    //   console.log( 'divdiv' )
    //   // e.stopPropagation()
    // }
    // p.onclick = function(e) { 
    //   console.log('pppppppppp')
    //   e.stopPropagation()
    // }

    //  addEventListener  1.  可以注册多个事件  2. 可以在捕获阶段执行

    // 默认情况下， addEventLisetner 也是在 冒泡阶段执行
    div.addEventListener('click', function() {
      console.log('div执行了')
    })
    p.addEventListener('click', function(e) {
      console.log('pppppp执行了')
      e.stopPropagation()
    })
  </script>
</body>
</html>